Computer Programming Dynamic Charts তৈরি করা এবং Chart Automation গাইড ও নোট

268

VBA তে Dynamic Charts তৈরি করা এবং Chart Automation

Excel-এ Dynamic Charts তৈরি করা এবং Chart Automation এর মাধ্যমে আপনাকে আপনার ডেটা প্রদর্শনকে আরও ইন্টারঅ্যাকটিভ এবং অটোমেটিক করতে সাহায্য করবে। VBA (Visual Basic for Applications) ব্যবহার করে আপনি এই কাজগুলো সহজেই করতে পারেন, যার ফলে চার্টগুলি স্বয়ংক্রিয়ভাবে আপনার ডেটার পরিবর্তনের সাথে আপডেট হবে।

Dynamic Charts কী?

একটি Dynamic Chart হল এমন একটি চার্ট যা ডেটা পরিবর্তিত হলে স্বয়ংক্রিয়ভাবে আপডেট হয়। এটি সাধারণত Excel Data Range বা Named Range ব্যবহার করে তৈরি করা হয়, যা অটোমেটিক্যালি ডেটা পরিবর্তিত হলে চার্টের ডেটা আপডেট করতে সহায়ক।


Dynamic Chart তৈরি করার জন্য সাধারণ পদ্ধতি

1. Named Range তৈরি করা

এটি একটি কৌশল যেখানে আপনি ডেটার একটি রেঞ্জকে একটি নির্দিষ্ট নাম দেন, এবং যখন ডেটা পরিবর্তিত হয়, তখন সেই নামযুক্ত রেঞ্জের মানও পরিবর্তিত হয়। একে Dynamic Range বলা হয়।

Steps:

  1. Formula > Name Manager এ যান।
  2. New ক্লিক করুন এবং একটি নাম (যেমন: SalesData) প্রদান করুন।
  3. Refers To ফিল্ডে একটি ডাইনামিক ফর্মুলা ব্যবহার করুন (যেমন, =OFFSET(Sheet1!$A$1,0,0,COUNTA(Sheet1!$A:$A),1)), যা ডেটার আকার অনুসারে স্বয়ংক্রিয়ভাবে রেঞ্জ পরিবর্তিত হবে।

2. Dynamic Chart তৈরি করা

  1. এখন, আপনি যে Named Range তৈরি করেছেন সেটি ব্যবহার করে একটি চার্ট তৈরি করতে পারবেন।
  2. Insert > Chart নির্বাচন করুন এবং Chart Data Range হিসেবে আপনার Named Range ব্যবহার করুন।

3. Chart Update With New Data

যখন আপনি নতুন ডেটা যুক্ত করবেন, Named Range বা Dynamic Range এর মাধ্যমে চার্টটি স্বয়ংক্রিয়ভাবে আপডেট হবে।


VBA ব্যবহার করে Dynamic Chart তৈরি এবং Automation

VBA ব্যবহার করে আপনি Dynamic Chart তৈরি এবং Chart Automation সম্পাদন করতে পারেন। এটি আপনাকে ডেটার উপর ভিত্তি করে চার্ট তৈরি করতে এবং সেই চার্টকে স্বয়ংক্রিয়ভাবে আপডেট করতে সহায়তা করবে।

1. Basic Dynamic Chart Creation with VBA

Sub CreateDynamicChart()
    Dim chartObj As ChartObject
    Dim chartRange As Range
    
    ' ডেটার রেঞ্জ নির্বাচন করুন
    Set chartRange = Range("A1:B10") ' এখানে A1:B10 রেঞ্জটি আপনার ডেটার জন্য হবে
    
    ' নতুন চার্ট তৈরি করুন
    Set chartObj = ActiveSheet.ChartObjects.Add(Left:=100, Width:=375, Top:=75, Height:=225)
    With chartObj.Chart
        .SetSourceData Source:=chartRange
        .ChartType = xlLine ' লাইন চার্ট নির্বাচন
        .HasTitle = True
        .ChartTitle.Text = "Dynamic Sales Chart"
    End With
End Sub

এখানে:

  • chartRange হল চার্টের জন্য ডেটার রেঞ্জ।
  • ChartObjects.Add মেথড ব্যবহার করে একটি নতুন চার্ট তৈরি করা হয়েছে।
  • SetSourceData এর মাধ্যমে আপনি ডেটা রেঞ্জ নির্বাচন করছেন।

2. Dynamic Chart with Named Range and VBA

এটি Named Range ব্যবহার করে একটি ডাইনামিক চার্ট তৈরি করার উদাহরণ:

Sub CreateDynamicChartUsingNamedRange()
    Dim chartObj As ChartObject
    Dim namedRange As String
    
    ' Named Range (Dynamic Range) ব্যবহার করুন
    namedRange = "SalesData"  ' আপনার নামকৃত রেঞ্জের নাম এখানে দিন
    
    ' নতুন চার্ট তৈরি করুন
    Set chartObj = ActiveSheet.ChartObjects.Add(Left:=100, Width:=375, Top:=75, Height:=225)
    With chartObj.Chart
        .SetSourceData Source:=Range(namedRange)  ' Named Range এর মাধ্যমে ডেটা নির্ধারণ
        .ChartType = xlLine ' লাইন চার্ট নির্বাচন
        .HasTitle = True
        .ChartTitle.Text = "Dynamic Sales Chart with Named Range"
    End With
End Sub

এখানে:

  • namedRange একটি Named Range ব্যবহার করা হয়েছে, যা আগে Excel-এ তৈরি করা হয়েছিল (যেমন: SalesData নামের রেঞ্জ)।

3. Chart Automation: Updating Chart Automatically

ধরা যাক, আপনি একটি চার্ট আপডেট করতে চান যখন ডেটা পরিবর্তন হয় (অথবা নতুন ডেটা অ্যাড করা হয়)। এটি করতে, আপনি Worksheet Change Event ব্যবহার করতে পারেন।

Private Sub Worksheet_Change(ByVal Target As Range)
    Dim chartObj As ChartObject
    Dim dataRange As Range

    ' যদি A1:B10 রেঞ্জে কোনো পরিবর্তন হয়, তবে চার্ট আপডেট হবে
    If Not Intersect(Target, Me.Range("A1:B10")) Is Nothing Then
        Set dataRange = Me.Range("A1:B10") ' ডেটার রেঞ্জ
        Set chartObj = Me.ChartObjects("Chart 1") ' চার্ট অবজেক্ট

        ' চার্টের ডেটা আপডেট করুন
        chartObj.Chart.SetSourceData Source:=dataRange
    End If
End Sub

এখানে:

  • Worksheet_Change ইভেন্ট ব্যবহার করা হয়েছে যাতে ব্যবহারকারী যখন ডেটা পরিবর্তন করবেন, তখন চার্ট স্বয়ংক্রিয়ভাবে আপডেট হবে।

4. Automating Chart Type and Customization

এখানে একটি উদাহরণ দেওয়া হলো যেখানে VBA এর মাধ্যমে চার্ট টাইপ এবং কাস্টমাইজেশন করা হয়েছে:

Sub CreateCustomizedChart()
    Dim chartObj As ChartObject
    Dim dataRange As Range
    
    ' ডেটার রেঞ্জ নির্বাচন করুন
    Set dataRange = Range("A1:B10")
    
    ' নতুন চার্ট তৈরি করুন
    Set chartObj = ActiveSheet.ChartObjects.Add(Left:=100, Width:=375, Top:=75, Height:=225)
    With chartObj.Chart
        .SetSourceData Source:=dataRange
        .ChartType = xlColumnClustered ' কলাম চার্ট নির্বাচন
        .HasTitle = True
        .ChartTitle.Text = "Sales Data"
        
        ' এক্স-অক্ষ এবং ওয়াই-অক্ষ টাইটেল যোগ করা
        .Axes(xlCategory, xlPrimary).HasTitle = True
        .Axes(xlCategory, xlPrimary).AxisTitle.Text = "Months"
        
        .Axes(xlValue, xlPrimary).HasTitle = True
        .Axes(xlValue, xlPrimary).AxisTitle.Text = "Sales"
        
        ' গ্রিডলাইন শো করা
        .Axes(xlValue).MajorGridlines.Border.Color = RGB(200, 200, 200)
    End With
End Sub

এখানে:

  • xlColumnClustered দিয়ে কলাম চার্ট তৈরি করা হয়েছে।
  • Axes ব্যবহার করে x-axis এবং y-axis এর টাইটেল যোগ করা হয়েছে।
  • MajorGridlines সেট করা হয়েছে যাতে গ্রিডলাইনগুলি প্রদর্শিত হয়।

সারসংক্ষেপ

  • Dynamic Charts হল এমন চার্ট যা ডেটার পরিবর্তনের সাথে আপডেট হয়, এবং এর জন্য Named Range বা Dynamic Range ব্যবহার করা হয়।
  • VBA এর মাধ্যমে আপনি Dynamic Charts তৈরি করতে পারেন এবং সেই চার্টের স্বয়ংক্রিয় আপডেট ও কাস্টমাইজেশন করতে পারেন।
  • Chart Automation করতে, আপনি Worksheet Change Event ব্যবহার করতে পারেন যাতে ডেটা পরিবর্তিত হলে চার্ট স্বয়ংক্রিয়ভাবে আপডেট হয়।

এই কৌশলগুলি আপনাকে Excel ডেটাকে আরো ইন্টারঅ্যাকটিভ এবং অটোমেটেডভাবে প্রদর্শন করতে সাহায্য করবে, যা ডেটা বিশ্লেষণ এবং রিপোর্টিং সহজ করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...